<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script>
        //自己理解 : 就是一个函数有权访问另一个函数作用域中的值   通常是一个内部函数,并且被返回出去了
        
        window.onload = function(){
            var oLi = document.getElementsByTagName('li');
            // for(var i = 0;i<oLi.length;i++){
            //     oLi[i].onclick = function(){
            //         alert(i) //全部打印的是一个值
            //     }
            // }
           for(var i = 0;i<oLi.length;i++){
                oLi[i].onclick = (function(j){
                   return function(){
                       alert(j)
                   }
                })(i)
            }
           
        }
       
    </script>
</head>
<body>
        <ul>
            <li>aaaaaa</li>
            <li>aaaaaa</li>
            <li>aaaaaa</li>
            <li>aaaaaa</li>
            <li>aaaaaa</li>
            <li>aaaaaa</li>
        </ul>
</body>
</html>